# **Laboratory 2**

(Due date: **004/011**: Oct. 5<sup>th</sup>, **005**: Oct. 6<sup>th</sup>, **007**: Oct. 7<sup>th</sup>)

# OBJECTIVES

- ✓ Use the Structural Description on VHDL.
- ✓ Test arithmetic circuits on an FPGA.

# VHDL CODING

✓ Refer to the <u>Tutorial: VHDL for FPGAs</u> for a list of examples.

# **FIRST ACTIVITY (100/100)**

## DESIGN PROBLEM

• Addition of four 4-bit unsigned numbers. The addition result requires 6 bits. This circuit can be built out of two 4-bit adders and one 5-bit adder as depicted in the figure.



• The figure below depicts the internal architecture of the 4-bit adder and the 5-bit adder. The full adder circuit is also shown.



## PROCEDURE

- Vivado: Complete the following steps:
  - ✓ Create a new Vivado Project. Select the corresponding Artix-7 FPGA device (e.g.: the XC7A50T-1CSG324 FPGA device for the Nexys A7-50T).
  - $\checkmark$  Write the VHDL code for the BCD Adder.
    - Use the Structural Description: Create a separate .vhd file for the Full Adder, the 4-bit adder, the 5-bit adder, and the top file (adder of four 4-bit numbers).
  - $\checkmark$  Write the VHDL testbench to test the circuit for the following cases:
    - A=0xB, B=0x5, C=0xE, D=0xC  $\rightarrow$  S=101010
    - A=0xF, B=0x7, C=0xD, D=0x3 → S=100110
    - $\mathbf{A}=0\times\mathbf{A}$ ,  $\mathbf{B}=0\times\mathbf{6}$ ,  $\mathbf{C}=0\times\mathbf{4}$ ,  $\mathbf{D}=0\times\mathbf{8}$   $\rightarrow$   $\mathbf{S}=011100$
    - A=0x8, B=0xE, C=0xF, D=0x9 → S=101110

1

#### ✓ Perform <u>Functional Simulation</u> of your design. **Demonstrate this to your TA**.

- Add the internal signals (R, T) to the waveform view. Go to: SCOPE window: testbench  $\rightarrow$  UUT. Then go to Objects Window  $\rightarrow$  Signal(s)  $\rightarrow$  Add to Wave Window. Finally, re-run the simulation.
  - This step is extremely useful when debugging your circuit. Your circuit might be cleared of syntax errors, but there might still be errors that can be difficult to spot. By tracing the internal signals, we can determine where the error is located in the circuit.
  - ✓ For example: In this circuit, for a given set of input values, we know the expected output values and we can compute the internal signal values. Then, we compare those values with those provided by the simulation:
    - If the output s is incorrect (simulation results do not match the expected values), we then look at the value of the internal signals R and T.
      - If the values of R and T are correct (i.e., simulation results match the calculated values), then the error is located in the lower (5-bit) adder.
      - If the value of R is incorrect, then the error is on the right 4-bit adder.
      - If the value of T is incorrect, then the error is on the left 4-bit adder.
- For the following set of inputs, complete the expected values of the listed internal signals. Then, run the simulation and compare the values in the simulation waveform with the ones you computed. This will help you figure out where the errors (if any) are located at.

| A    | В    | С    | D    | R | Т | S    |
|------|------|------|------|---|---|------|
| 1011 | 0101 | 1110 | 1100 |   |   | 0100 |
| 1111 | 0111 | 1101 | 0011 |   |   | 1001 |

 $\checkmark~$  I/O Assignment: Generate the XDC file associated with your board.

Suggestion:

| Board pin names      | SW15-SW12 | SW11-SW8 | SW7-SW4 | SW3-SW0 | LED5 | LED4  | LED3           | LED2  | LED1  | LED0           |
|----------------------|-----------|----------|---------|---------|------|-------|----------------|-------|-------|----------------|
| Signal names in code | A3-A0     | B3-B0    | C3-C0   | D3-D0   | S 5  | $S_4$ | S <sub>3</sub> | $S_2$ | $S_1$ | S <sub>0</sub> |

- The board pin names are used by all the listed boards (Nexys A7-50T/A7-100T, Basys 3, Nexys 4/DDR). The I/Os listed here are all active high.
- ✓ Implement your design (Run Implementation) and run <u>Timing Simulation</u>.
- ✓ Generate and download the bitstream on the FPGA, then perform testing. **Demonstrate this to your TA**.
- Submit (<u>as a .zip file</u>) the six generated files: VHDL code (4 files), VHDL testbench, and XDC file to Moodle (an assignment will be created). DO NOT submit the whole Vivado Project.
  - ✓ Your .zip file should only include one folder. Do not include subdirectories.

| √ | It is strongly recommended that all your design files, testbench, and constraints   |
|---|-------------------------------------------------------------------------------------|
|   | file be located in a single directory. This will allow for a smooth experience with |
|   | Vivado.                                                                             |



TA signature: \_\_\_\_\_

| Date: |  |
|-------|--|
|-------|--|